

<script setup lang="ts">
	import { ref } from 'vue'
	import { onLoad,onReady } from '@dcloudio/uni-app'
	import { loginType ,MyEnumType} from '../../types/login'
	import { postLoginApi } from '../../api/login' 
	const code = ref('')
	// #ifdef H5 || MP-WEIXIN
	const getLoginCode = async ()=>{
		const res =await wx.login()
		console.log(res,'res===========')
		code.value = res.code
		
		
		console.log(code.value,'code')
		console.log(res,'res')
	}
	
	
	// #endif
	


 // #ifdef APP-PLUS
 
       const getLoginCodeApp = ()=>{
		   uni.login({
			  provider:'weixin',
			  success:function(res){
			  	console.log(res)
					uni.getUserInfo({
						provider:'weixin',
						success: (infoRes) => {
							console.log(infoRes)
							uni.switchTab({
								url:'/pages/index/index'
							})
						}
					})
			  }
		   })
	   }

// onLoad(()=>{
// 	getLoginCodeApp()
// })

// onReady(()=>{
// 	getLoginCodeApp()
// })
 // #endif
	
	// 微信登录
  const onGetuserinfo = async (event :any )=>{
	  const data :loginType = {
		  iv:event.detail.iv,
		  code : code.value,
		  encryptedData:event.detail.encryptedData
	  }
	  console.log(data,'data')
  
  }
  
  const goToAgreement = (type :MyEnumType )=>{
	  uni.navigateTo({
	  	url:`/pages/agreement/agreement?agreementName=${type}`
	  })
  }
</script>

<template>
  <view class="viewport">
    <view class="logoImage">
      <image
        src="https://pcapi-xiaotuxian-front-devtest.itheima.net/miniapp/images/logo_icon.png"
      ></image>
    </view>
    <view class="login">

      <!-- 小程序端授权登录 -->

	  <button class="button phone wechat" open-type="getUserInfo" @click="getLoginCodeApp" @getuserinfo="onGetuserinfo">
	    <text class="icon icon-phone"></text>
	    微信登录
	  </button>
      <view class="extra">


      </view>
      <view class="tips">登录/注册即视为你同意
	  <text class="link" @click="goToAgreement('user')">《服务条款》</text>
	  和
	  <text class="link" @click="goToAgreement('privacy-Agreement')">《小兔鲜儿隐私协议》</text>
	  </view>
    </view>
  </view>
</template>

<style lang="scss">
page {
  height: 100%;
}

.viewport {
  display: flex;
  flex-direction: column;
  height: 100%;
  padding: 20rpx 40rpx;
}

.logoImage {
  flex: 1;
  text-align: center;
  image {
    width: 220rpx;
    height: 220rpx;
    margin-top: 15vh;
  }
}

.login {
  display: flex;
  flex-direction: column;
  height: 60vh;
  padding: 40rpx 20rpx 20rpx;

  .input {
    width: 100%;
    height: 80rpx;
    font-size: 28rpx;
    border-radius: 72rpx;
    border: 1px solid #ddd;
    padding-left: 30rpx;
    margin-bottom: 20rpx;
  }

  .button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    height: 80rpx;
    font-size: 28rpx;
    border-radius: 72rpx;
    color: #fff;
    .icon {
      font-size: 40rpx;
      margin-right: 6rpx;
    }
  }

  .phone {
    background-color: #28bb9c;
  }

  .wechat {
    background-color: #06c05f;
	margin-top: 20rpx;
  }

  .extra {
    flex: 1;
    padding: 70rpx 70rpx 0;
    .caption {
      width: 440rpx;
      line-height: 1;
      border-top: 1rpx solid #ddd;
      font-size: 26rpx;
      color: #999;
      position: relative;
      text {
        transform: translate(-40%);
        background-color: #fff;
        position: absolute;
        top: -12rpx;
        left: 50%;
      }
    }

    .options {
      display: flex;
      justify-content: center;
      align-items: center;
      margin-top: 70rpx;
	  padding: 20rpx;
	  box-sizing: border-box;
      button {
        padding: 10rpx;
        background-color: transparent;
		box-sizing: border-box;
		border-radius:10rpx;
      }
    }

    .icon {
      font-size: 24rpx;
      color: #444;
      display: flex;
      flex-direction: column;
      align-items: center;

      &::before {
        display: flex;
        align-items: center;
        justify-content: center;
        width: 80rpx;
        height: 80rpx;
        margin-bottom: 6rpx;
        font-size: 40rpx;
        border: 1rpx solid #444;
        border-radius: 50%;
      }
    }
    .icon-weixin::before {
      border-color: #06c05f;
      color: #06c05f;
    }
  }
}

.tips {
  position: absolute;
  bottom: 80rpx;
  left: 20rpx;
  right: 20rpx;
  font-size: 22rpx;
  color: #999;
  text-align: center;
  
  .link {
	  cursor:pointer;
	color: blue;
  }
}
</style>